/*
 *
 *    Copyright (c) 2022 Project CHIP Authors
 *
 *    Licensed under the Apache License, Version 2.0 (the "License");
 *    you may not use this file except in compliance with the License.
 *    You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 *    Unless required by applicable law or agreed to in writing, software
 *    distributed under the License is distributed on an "AS IS" BASIS,
 *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *    See the License for the specific language governing permissions and
 *    limitations under the License.
 */

// THIS FILE IS GENERATED BY ZAP
// This file is generated from clusters-Enums.h.zapt

#pragma once

#include <clusters/shared/Enums.h>
#include <cstdint>

namespace chip
{
namespace app
{
	namespace Clusters
	{
		namespace PushAvStreamTransport
		{

			// Enum for CMAFInterfaceEnum
			enum class CMAFInterfaceEnum : uint8_t {
				kInterface1 = 0x00,
				kInterface2DASH = 0x01,
				kInterface2HLS = 0x02,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 3,
			};

			// Enum for ContainerFormatEnum
			enum class ContainerFormatEnum : uint8_t {
				kCmaf = 0x00,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 1,
			};

			// Enum for IngestMethodsEnum
			enum class IngestMethodsEnum : uint8_t {
				kCMAFIngest = 0x00,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 1,
			};

			// Enum for StatusCodeEnum
			enum class StatusCodeEnum : uint8_t {
				kInvalidTLSEndpoint = 0x02,
				kInvalidStream = 0x03,
				kInvalidURL = 0x04,
				kInvalidZone = 0x05,
				kInvalidCombination = 0x06,
				kInvalidTriggerType = 0x07,
				kInvalidTransportStatus = 0x08,
				kInvalidOptions = 0x09,
				kInvalidStreamUsage = 0x0A,
				kInvalidTime = 0x0B,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 0,
			};

			// Enum for TransportStatusEnum
			enum class TransportStatusEnum : uint8_t {
				kActive = 0x00,
				kInactive = 0x01,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 2,
			};

			// Enum for TransportTriggerTypeEnum
			enum class TransportTriggerTypeEnum : uint8_t {
				kCommand = 0x00,
				kMotion = 0x01,
				kContinuous = 0x02,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 3,
			};

			// Enum for TriggerActivationReasonEnum
			enum class TriggerActivationReasonEnum : uint8_t {
				kUserInitiated = 0x00,
				kAutomation = 0x01,
				kEmergency = 0x02,
				// All received enum values that are not listed above will be mapped
				// to kUnknownEnumValue. This is a helper enum value that should only
				// be used by code to process how it handles receiving and unknown
				// enum value. This specific should never be transmitted.
				kUnknownEnumValue = 3,
			};

			// Bitmap for Feature
			enum class Feature : uint32_t {
				kPerZoneSensitivity = 0x1,
				kMetadata = 0x2,
			};
		} // namespace PushAvStreamTransport
	} // namespace Clusters
} // namespace app
} // namespace chip
